/**
 * 添加拦截器:
 *   拦截 request 请求
 *   拦截 uploadFile 文件上传
 *
 * TODO:
 *   1. 非 http 开头需拼接地址
 *   2. 请求超时
 *   3. 添加小程序端请求头标识
 *   4. 添加 token 请求头标识
 */

// import { useMemberStore } from '@/stores'

// const baseURL = 'http://103.148.59.132:10001'

// 添加拦截器
const httpInterceptor = {
	// 拦截前触发
	invoke(options : UniApp.RequestOptions) {
		// console.log(options)
		// 1. 非 http 开头需拼接地址
		if (!options.url.startsWith('http')) {
			options.url = options.url
		}
		// 2. 请求超时, 默认 60s
		options.timeout = 8000
		// 3. 添加小程序端请求头标识
		options.header = {
			...options.header,
			'source-client': 'miniapp',
		}
		// 4. 添加 token 请求头标识
		const token = uni.getStorageSync('token')
		if (token) {
			// 判断token值
			options.header.Authorization = token
		}
	}
}
uni.addInterceptor('request', httpInterceptor)
uni.addInterceptor('uploadFile', httpInterceptor)

/**
 * 请求函数
 * @param  UniApp.RequestOptions
 * @returns Promise
 *  1. 返回 Promise 对象
 *  2. 获取数据成功
 *    2.1 提取核心数据 res.data
 *    2.2 添加类型，支持泛型
 *  3. 获取数据失败
 *    3.1 401错误  -> 清理用户信息，跳转到登录页
 *    3.2 其他错误 -> 根据后端错误信息轻提示
 *    3.3 网络错误 -> 提示用户换网络
 */
type Data<T> = {
	code : string | number
	msg : string
	data : T
	rows : T | null
	total : number | null
}
// 2.2 添加类型，支持泛型
export const http = <T>(options : UniApp.RequestOptions) => {
	// console.log(options)
	// 1. 返回 Promise 对象
	return new Promise<Data<T>>((resolve, reject) => {
		console.log({ ...options })
		uni.request({
			// url: options.url,
			// method: options.method,
			...options,
			// 响应成功
			success(res) {
				console.log(111, res)
				// 状态码 2xx， axios 就是这样设计的
				if (res.statusCode >= 200 && res.statusCode <= 301) {
					// 2.1 提取核心数据 res.data
					if (res.data.code === 401) {
						// 401错误  -> 清理用户信息，跳转到登录页
						// localStorage.removeItem('token')
						// memberStore.clearProfile()
						uni.showToast({
							icon: 'none',
							title: 'token失效',
						})
						uni.navigateTo({ url: '/' })
						// reject(res)
					}
				resolve(res.data as Data<T>)
			} else {
				// 其他错误 -> 根据后端错误信息轻提示
					uni.showToast({
						icon: 'none',
						title: (res.data as Data<T>).msg || '请求错误',
					})
					reject(res)
			}
		},
			// 响应失败
			fail(err) {
			uni.showToast({
				icon: 'none',
				title: '网络错误，换个网络试试',
			})
				reject(err)
		},
		})
})
}